<!DOCTYPE html>
<html lang="zh" dir="ltr" class="client-nojs">
<head>
<title>浮点常量</title>
<meta charset="UTF-8">
<meta name="generator" content="MediaWiki 1.21.2">
<link rel="shortcut icon" href="../../../common/favicon.ico">
<link rel="stylesheet" href="../../../common/ext.css">
<meta name="ResourceLoaderDynamicStyles" content="">
<link rel="stylesheet" href="../../../common/site_modules.css">
<style>a:lang(ar),a:lang(ckb),a:lang(fa),a:lang(kk-arab),a:lang(mzn),a:lang(ps),a:lang(ur){text-decoration:none}#toc{display:none}.editsection{display:none}
/* cache key: mwiki1-mwiki_zh_:resourceloader:filter:minify-css:7:15cea3ec788a65b5187d4018eed543bf */</style>

<script src="../../../common/startup_scripts.js"></script>
<script>if(window.mw){
mw.config.set({"wgCanonicalNamespace":"","wgCanonicalSpecialPageName":false,"wgNamespaceNumber":0,"wgPageName":"c/language/floating_constant","wgTitle":"c/language/floating constant","wgCurRevisionId":72851,"wgArticleId":7925,"wgIsArticle":true,"wgAction":"view","wgUserName":null,"wgUserGroups":["*"],"wgCategories":[],"wgBreakFrames":false,"wgPageContentLanguage":"zh","wgSeparatorTransformTable":["",""],"wgDigitTransformTable":["",""],"wgDefaultDateFormat":"zh","wgMonthNames":["","1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"],"wgMonthNamesShort":["","1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"],"wgRelevantPageName":"c/language/floating_constant","wgUserVariant":"zh","wgRestrictionEdit":[],"wgRestrictionMove":[]});
}</script><script>if(window.mw){
mw.loader.implement("user.options",function(){mw.user.options.set({"ccmeonemails":0,"cols":80,"date":"default","diffonly":0,"disablemail":0,"disablesuggest":0,"editfont":"default","editondblclick":0,"editsection":0,"editsectiononrightclick":0,"enotifminoredits":0,"enotifrevealaddr":0,"enotifusertalkpages":1,"enotifwatchlistpages":0,"extendwatchlist":0,"externaldiff":0,"externaleditor":0,"fancysig":0,"forceeditsummary":0,"gender":"unknown","hideminor":0,"hidepatrolled":0,"imagesize":2,"justify":0,"math":1,"minordefault":0,"newpageshidepatrolled":0,"nocache":0,"noconvertlink":0,"norollbackdiff":0,"numberheadings":0,"previewonfirst":0,"previewontop":1,"quickbar":5,"rcdays":7,"rclimit":50,"rememberpassword":0,"rows":25,"searchlimit":20,"showhiddencats":0,"showjumplinks":1,"shownumberswatching":1,"showtoc":0,"showtoolbar":1,"skin":"cppreference2","stubthreshold":0,"thumbsize":2,"underline":2,"uselivepreview":0,"usenewrc":0,"watchcreations":0,"watchdefault":0,"watchdeletion":0,
"watchlistdays":3,"watchlisthideanons":0,"watchlisthidebots":0,"watchlisthideliu":0,"watchlisthideminor":0,"watchlisthideown":0,"watchlisthidepatrolled":0,"watchmoves":0,"wllimit":250,"variant":"zh","language":"zh","searchNs0":true,"searchNs1":false,"searchNs2":false,"searchNs3":false,"searchNs4":false,"searchNs5":false,"searchNs6":false,"searchNs7":false,"searchNs8":false,"searchNs9":false,"searchNs10":false,"searchNs11":false,"searchNs12":false,"searchNs13":false,"searchNs14":false,"searchNs15":false,"gadget-MathJax":1,"gadget-ColiruCompiler":1});;},{},{});mw.loader.implement("user.tokens",function(){mw.user.tokens.set({"editToken":"+\\","patrolToken":false,"watchToken":false});;},{},{});
/* cache key: mwiki1-mwiki_zh_:resourceloader:filter:minify-js:7:258d7cd6aa9aa67dee25e01fb6a9e505 */
}</script>
<script>if(window.mw){
mw.loader.load(["mediawiki.page.startup","mediawiki.legacy.wikibits","mediawiki.legacy.ajax"]);
}</script>
<style type="text/css">/*<![CDATA[*/
.source-c {line-height: normal;}
.source-c li, .source-c pre {
	line-height: normal; border: 0px none white;
}
/**
 * GeSHi Dynamically Generated Stylesheet
 * --------------------------------------
 * Dynamically generated stylesheet for c
 * CSS class: source-c, CSS id: 
 * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann
 * (http://qbnz.com/highlighter/ and http://geshi.org/)
 * --------------------------------------
 */
.c.source-c .de1, .c.source-c .de2 {font: normal normal 1em/1.2em monospace; margin:0; padding:0; background:none; vertical-align:top;}
.c.source-c  {font-family:monospace;}
.c.source-c .imp {font-weight: bold; color: red;}
.c.source-c li, .c.source-c .li1 {font-weight: normal; vertical-align:top;}
.c.source-c .ln {width:1px;text-align:right;margin:0;padding:0 2px;vertical-align:top;}
.c.source-c .li2 {font-weight: bold; vertical-align:top;}
.c.source-c .kw1 {color: #0000dd;}
.c.source-c .kw2 {color: #0000ff;}
.c.source-c .kw3 {color: #0000dd;}
.c.source-c .kw4 {color: #0000ff;}
.c.source-c .co1 {color: #909090;}
.c.source-c .co2 {color: #339900;}
.c.source-c .coMULTI {color: #ff0000; font-style: italic;}
.c.source-c .es0 {color: #008000; font-weight: bold;}
.c.source-c .es1 {color: #008000; font-weight: bold;}
.c.source-c .es2 {color: #008000; font-weight: bold;}
.c.source-c .es3 {color: #008000; font-weight: bold;}
.c.source-c .es4 {color: #008000; font-weight: bold;}
.c.source-c .es5 {color: #008000; font-weight: bold;}
.c.source-c .br0 {color: #008000;}
.c.source-c .sy0 {color: #008000;}
.c.source-c .sy1 {color: #000080;}
.c.source-c .sy2 {color: #000040;}
.c.source-c .sy3 {color: #000040;}
.c.source-c .sy4 {color: #008080;}
.c.source-c .st0 {color: #008000;}
.c.source-c .nu0 {color: #000080;}
.c.source-c .nu6 {color:#000080;}
.c.source-c .nu8 {color:#000080;}
.c.source-c .nu12 {color:#000080;}
.c.source-c .nu16 {color:#000080;}
.c.source-c .nu17 {color:#000080;}
.c.source-c .nu18 {color:#000080;}
.c.source-c .nu19 {color:#000080;}
.c.source-c .ln-xtra, .c.source-c li.ln-xtra, .c.source-c div.ln-xtra {background-color: #ffc;}
.c.source-c span.xtra { display:block; }

/*]]>*/
</style><style type="text/css">/*<![CDATA[*/
.source-text {line-height: normal;}
.source-text li, .source-text pre {
	line-height: normal; border: 0px none white;
}
/**
 * GeSHi Dynamically Generated Stylesheet
 * --------------------------------------
 * Dynamically generated stylesheet for text
 * CSS class: source-text, CSS id: 
 * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann
 * (http://qbnz.com/highlighter/ and http://geshi.org/)
 * --------------------------------------
 */
.text.source-text .de1, .text.source-text .de2 {font: normal normal 1em/1.2em monospace; margin:0; padding:0; background:none; vertical-align:top;}
.text.source-text  {font-family:monospace;}
.text.source-text .imp {font-weight: bold; color: red;}
.text.source-text li, .text.source-text .li1 {font-weight: normal; vertical-align:top;}
.text.source-text .ln {width:1px;text-align:right;margin:0;padding:0 2px;vertical-align:top;}
.text.source-text .li2 {font-weight: bold; vertical-align:top;}
.text.source-text .ln-xtra, .text.source-text li.ln-xtra, .text.source-text div.ln-xtra {background-color: #ffc;}
.text.source-text span.xtra { display:block; }

/*]]>*/
</style><!--[if lt IE 7]><style type="text/css">body{behavior:url("/mwiki/skins/cppreference2/csshover.min.htc")}</style><![endif]--></head>
<body class="mediawiki ltr sitedir-ltr ns-0 ns-subject page-c_language_floating_constant skin-cppreference2 action-view cpp-navbar">
        <!-- header -->
        <!-- /header -->
        <!-- content -->
<div id="cpp-content-base">
            <div id="content">
                <a id="top"></a>
                <div id="mw-js-message" style="display:none;"></div>
                                <!-- firstHeading -->
<h1 id="firstHeading" class="firstHeading">浮点常量</h1>
                <!-- /firstHeading -->
                <!-- bodyContent -->
                <div id="bodyContent">
                                        <!-- tagline -->
                    <div id="siteSub">来自cppreference.com</div>
                    <!-- /tagline -->
                                        <!-- subtitle -->
                    <div id="contentSub"><span class="subpages">&lt; <a href="../../c.html" title="c">c</a>‎ | <a href="../language.html" title="c/language">language</a></span></div>
                    <!-- /subtitle -->
                                                            <!-- bodycontent -->
                    <div id="mw-content-text" lang="zh" dir="ltr" class="mw-content-ltr"><div class="t-navbar" style=""><div class="t-navbar-sep"> </div><div class="t-navbar-head"><a href="../../c.html" title="c"> C</a><div class="t-navbar-menu"><div><div><table class="t-nv-begin" cellpadding="0" style="line-height:1.1em">
<tr class="t-nv"><td colspan="5"> <a href="../language.html" title="c/language">语言</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../header.html" title="c/header">头文件</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../types.html" title="c/types">类型支持</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../program.html" title="c/program">程序工具</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../variadic.html" title="c/variadic">变参数函数支持</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../memory.html" title="c/memory">动态内存管理</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../error.html" title="c/error">错误处理</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../chrono.html" title="c/chrono">日期和时间工具</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../string.html" title="c/string">字符串库</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../algorithm.html" title="c/algorithm">算法</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../numeric.html" title="c/numeric">数值</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../io.html" title="c/io">输入/输出支持</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../locale.html" title="c/locale">本地化支持</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../thread.html" title="c/thread">线程支持</a> <span class="t-mark-rev t-since-c11">(C11)</span> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../atomic.html" title="c/atomic">原子操作</a> <span class="t-mark-rev t-since-c11">(C11)</span> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="../experimental.html" title="c/experimental">技术规范</a> </td></tr>
</table></div><div></div></div></div></div><div class="t-navbar-sep"> </div><div class="t-navbar-head"><a href="../language.html" title="c/language">C 语言</a><div class="t-navbar-menu"><div><div><table class="t-nv-begin" cellpadding="0" style="line-height:1.1em">
<tr class="t-nv-h2"><td colspan="5"> <a href="basic_concepts.html" title="c/language/basic concepts">基本概念</a></td></tr>
<tr class="t-nv-h2"><td colspan="5"> <a href="../keyword.html" title="c/keyword">关键词</a></td></tr>
<tr class="t-nv-h2"><td colspan="5"> <a href="../preprocessor.html" title="c/preprocessor">预处理器</a></td></tr>
<tr class="t-nv-h2"><td colspan="5"> <a href="statements.html" title="c/language/statements">语句</a></td></tr>
<tr class="t-nv-h2"><td colspan="5"> <a href="expressions.html" title="c/language/expressions">表达式</a></td></tr>
<tr class="t-nv-h2"><td colspan="5"> <a href="initialization.html" title="c/language/initialization">初始化</a></td></tr>
<tr class="t-nv-h2"><td colspan="5"> <a href="declarations.html" title="c/language/declarations">声明</a></td></tr>
<tr class="t-nv-h2"><td colspan="5"> <a href="functions.html" title="c/language/functions">函数</a></td></tr>
<tr class="t-nv"><td colspan="5"> 杂项</td></tr>
<tr class="t-nv-h2"><td colspan="5"> <a href="history.html" title="c/language/history">C 的历史</a></td></tr>
<tr class="t-nv-h2"><td colspan="5"> <a href="../experimental.html" title="c/experimental">技术规范</a> </td></tr>
</table></div><div></div></div></div></div><div class="t-navbar-sep"> </div><div class="t-navbar-head"><a href="expressions.html" title="c/language/expressions"> 表达式</a><div class="t-navbar-menu"><div><div style="display:inline-block">
<div><table class="t-nv-begin" cellpadding="0" style="line-height:1.1em">
<tr class="t-nv-h2"><td colspan="5"> 通用 </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="value_category.html" title="c/language/value category">值类别</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="eval_order.html" title="c/language/eval order"> 求值顺序与顺序点</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="constant_expression.html" title="c/language/constant expression">常量表达式</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="conversion.html" title="c/language/conversion">隐式转换</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="generic.html" title="c/language/generic">泛型选择</a></td></tr>
<tr class="t-nv-h2"><td colspan="5"> <a href="expressions.html#.E5.B8.B8.E9.87.8F.E5.8F.8A.E5.AD.97.E9.9D.A2.E9.87.8F" title="c/language/expressions">常量及字面量</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="integer_constant.html" title="c/language/integer constant">整数常量</a></td></tr>
<tr class="t-nv"><td colspan="5"> <strong class="selflink">浮点常量</strong></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="character_constant.html" title="c/language/character constant">字符常量</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="string_literal.html" title="c/language/string literal">字符串字面量</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="compound_literal.html" title="c/language/compound literal">复合字面量</a></td></tr>
<tr class="t-nv-h2"><td colspan="5"> <a href="expressions.html#.E8.BF.90.E7.AE.97.E7.AC.A6" title="c/language/expressions">运算符</a> </td></tr>
<tr class="t-nv"><td colspan="5"> <a href="operator_precedence.html" title="c/language/operator precedence">运算符优先级</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="operator_member_access.html" title="c/language/operator member access">成员访问与间接</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="operator_logical.html" title="c/language/operator logical">逻辑运算符</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="operator_comparison.html" title="c/language/operator comparison">比较运算符</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="operator_arithmetic.html" title="c/language/operator arithmetic">算术运算符</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="operator_assignment.html" title="c/language/operator assignment">赋值运算符</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="operator_incdec.html" title="c/language/operator incdec">自增减</a></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="operator_other.html" title="c/language/operator other">函数调用、逗号、条件运算符</a></td></tr>
<tr class="t-nv"><td colspan="5"><div class="t-nv-ln-table"><div><a href="sizeof.html" title="c/language/sizeof"><span class="t-lines"><span>sizeof</span></span></a></div></div></td></tr>
<tr class="t-nv"><td colspan="5"><div class="t-nv-ln-table"><div><a href="_Alignof.html" title="c/language/ Alignof"><span class="t-lines"><span>_Alignof</span></span></a></div><div><span class="t-lines"><span><span class="t-mark-rev t-since-c11">(C11)</span></span></span></div></div></td></tr>
<tr class="t-nv"><td colspan="5"> <a href="cast.html" title="c/language/cast">转型运算符</a></td></tr>
</table></div>
</div><div></div></div></div></div><div class="t-navbar-sep"> </div></div>
<p>允许直接在表达式中使用浮点类型值。
</p>
<h3><span class="mw-headline" id=".E8.AF.AD.E6.B3.95">语法</span></h3>
<p>浮点常量是<a href="value_category.html" title="c/language/value category">非左值</a>表达式，拥有下列形式
</p>
<table class="t-sdsc-begin">

<tr>
<td colspan="10" class="t-sdsc-sep">
</td></tr>
<tr class="t-sdsc">
<td class="t-sdsc-nopad"> <span class="t-spar">有效数字</span> <span class="t-spar">指数</span><span class="t-mark">(可选)</span> <span class="t-spar">后缀</span><span class="t-mark">(可选)</span>
</td>
<td class="t-sdsc-nopad">
</td>
<td class="t-sdsc-nopad">
</td></tr>



<tr>
<td colspan="10" class="t-sdsc-sep">
</td></tr></table>
<p>其中 <span class="t-spar">有效数字</span> 拥有形式
</p>
<table class="t-sdsc-begin">

<tr>
<td colspan="10" class="t-sdsc-sep">
</td></tr>
<tr class="t-sdsc">
<td class="t-sdsc-nopad"> <span class="t-spar">整数</span><span class="t-mark">(可选)</span> <code><b>.</b></code><span class="t-mark">(可选)</span> <span class="t-spar">小数</span><span class="t-mark">(可选)</span>
</td>
<td class="t-sdsc-nopad">
</td>
<td class="t-sdsc-nopad">
</td></tr>



<tr>
<td colspan="10" class="t-sdsc-sep">
</td></tr></table>
<p><span class="t-spar">指数</span> 拥有形式
</p>
<table class="t-sdsc-begin">

<tr>
<td colspan="10" class="t-sdsc-sep">
</td></tr>
<tr class="t-sdsc">
<td> <code><b>e</b></code> | <code><b>E</b></code> <span class="t-spar">指数符号</span><span class="t-mark">(可选)</span> <span class="t-spar">数字序列</span>
</td>
<td> (1)
</td>
<td class="t-sdsc-nopad">
</td></tr>



<tr>
<td colspan="10" class="t-sdsc-sep">
</td></tr>
<tr class="t-sdsc">
<td> <code><b>p</b></code> | <code><b>P</b></code> <span class="t-spar">指数符号</span><span class="t-mark">(可选)</span> <span class="t-spar">数字序列</span>
</td>
<td> (2)
</td>
<td> <span class="t-mark-rev t-since-c99">(C99 起)</span>
</td></tr>



<tr>
<td colspan="10" class="t-sdsc-sep">
</td></tr></table>
<div class="t-li1"><span class="t-li">1)</span> 十进制浮点常量的指数语法</div>
<div class="t-li1"><span class="t-li">2)</span> 十六进制浮点常量的指数语法</div>
 <table class="t-rev-begin">
<tr class="t-rev t-since-c23"><td>
<p>数位间可插入作为分隔符的单引号（<code>'</code>），在编译时忽略它们。
</p>
</td>
<td><span class="t-mark-rev t-since-c23">(C23 起)</span></td></tr>
</table>
<h3><span class="mw-headline" id=".E8.A7.A3.E9.87.8A">解释</span></h3>
 <table class="t-rev-begin">
<tr class="t-rev t-since-c99"><td>
<p>若 <span class="t-spar">有效数字</span> 以字符序列 <code>0x</code> 或 <code>0X</code> 开始，则浮点常量为<i>十六进制浮点常量</i>。否则，它是<i>十进制浮点常量</i>。
</p><p>对于<i>十六进制浮点常量</i>，将 <span class="t-spar">有效数字</span> 转译为十六进制小数，而将指数的 <span class="t-spar">数字序列</span> 转译为有效数字要乘的 2 的整数次幂。
</p>
<div dir="ltr" class="mw-geshi" style="text-align: left;"><div class="c source-c"><pre class="de1"><span class="kw4">double</span> d <span class="sy1">=</span> 0x1.2p3<span class="sy4">;</span> <span class="co1">// 十六进制小数 1.2 （十进制 1.125 ）乘 2^3 ，即 9.0</span></pre></div></div>
</td>
<td><span class="t-mark-rev t-since-c99">(C99 起)</span></td></tr>
</table>
<p>对于<i>十进制浮点常量</i>， <span class="t-spar">有效数字</span> 被转译为十进制小数，而将指数的 <span class="t-spar">数字序列</span> 转译为有效数字要乘的 10 的整数次幂。
</p>
<div dir="ltr" class="mw-geshi" style="text-align: left;"><div class="c source-c"><pre class="de1"><span class="kw4">double</span> d <span class="sy1">=</span> <span class="nu19">1.2e3</span><span class="sy4">;</span> <span class="co1">// 十进制小数 1.2 乘 10^3 ，即 1200.0</span></pre></div></div>
<h4><span class="mw-headline" id=".E5.90.8E.E7.BC.80">后缀</span></h4>
<p>无后缀浮点常量拥有 <span class="t-c"><span class="mw-geshi c source-c"><span class="kw4">double</span></span></span> 类型。若 <span class="t-spar">后缀</span> 为字母 <code><b>f</b></code> 或 <code><b>F</b></code> ，则浮点常量拥有 <span class="t-c"><span class="mw-geshi c source-c"><span class="kw4">float</span></span></span> 类型。若 <span class="t-spar">后缀</span> 为 <code><b>l</b></code> 或 <code><b>L</b></code> ，则浮点常量拥有 <span class="t-c"><span class="mw-geshi c source-c"><span class="kw4">long</span> <span class="kw4">double</span></span></span> 类型。
</p>
 <table class="t-rev-begin">
<tr class="t-rev t-since-c23"><td>
<p>若实现预定义宏 <code>__STDC_IEC_60559_BFP__</code> ，则额外支持下列后缀与对应的浮点常量：
</p>
<ul><li> 若 <span class="t-spar">后缀</span> 为 <code><b>df</b></code> 或 <code><b>DF</b></code> ，则浮点常量拥有 <span class="t-c"><span class="mw-geshi c source-c">_Decimal32</span></span> 类型；
</li><li> 若 <span class="t-spar">后缀</span> 为 <code><b>dd</b></code> 或 <code><b>DD</b></code> ，则浮点常量拥有 <span class="t-c"><span class="mw-geshi c source-c">_Decimal64</span></span> 类型；
</li><li> 若 <span class="t-spar">后缀</span> 为 <code><b>dl</b></code> 或 <code><b>DL</b></code> ，则浮点常量拥有 <span class="t-c"><span class="mw-geshi c source-c">_Decimal128</span></span> 类型。
</li></ul>
<p>十六进制浮点常量中不允许十进制浮点类型的后缀。
</p>
</td>
<td><span class="t-mark-rev t-since-c23">(C23 起)</span></td></tr>
</table>
<h4><span class="mw-headline" id=".E5.8F.AF.E9.80.89.E9.83.A8.E5.88.86">可选部分</span></h4>
<p>若有指数而不用小数部分，则可以忽略小数分隔符：
</p>
<div dir="ltr" class="mw-geshi" style="text-align: left;"><div class="c source-c"><pre class="de1"><span class="kw4">double</span> x <span class="sy1">=</span> <span class="nu19">1e0</span><span class="sy4">;</span> <span class="co1">// 浮点数 1.0 （不用小数点）</span></pre></div></div>
<p>对于十进制浮点常量， <span class="t-spar">指数</span> 部分是可选的。若忽略它，则小数点不是可选的，而且 <span class="t-spar">整数</span> 或 <span class="t-spar">小数</span> 必须存在。
</p>
<div dir="ltr" class="mw-geshi" style="text-align: left;"><div class="c source-c"><pre class="de1"><span class="kw4">double</span> x <span class="sy1">=</span> <span class="nu0">1</span>.<span class="sy4">;</span> <span class="co1">// 浮点数 1.0 （小数部分可选）</span>
<span class="kw4">double</span> y <span class="sy1">=</span> <span class="nu18">.1</span><span class="sy4">;</span> <span class="co1">// 浮点数 0.1 （整数部分可选）</span></pre></div></div>
 <table class="t-rev-begin">
<tr class="t-rev t-since-c99"><td>
<p>十六进制浮点常量的指数非可选，以避免误认 <code><b>f</b></code> 后缀为十六进制数字所导致的歧义结果。
</p>
</td>
<td><span class="t-mark-rev t-since-c99">(C99 起)</span></td></tr>
</table>
<h4><span class="mw-headline" id=".E5.8F.AF.E8.A1.A8.E7.A4.BA.E5.80.BC">可表示值</span></h4>
<p>浮点常量的求值结果是最邻近的可表示值，或紧邻于最邻近可表示值的最大或最小可表示值，以实现定义行为选择（换言之，翻译期的<a href="../numeric/fenv/FE_round.html" title="c/numeric/fenv/FE round">默认浮点方向</a>是实现定义的）。
</p><p>所有拥有相同源码形式的浮点常量都转换到有相同值的同一内部格式。有不同形式的浮点常量，例如 <span class="t-c"><span class="mw-geshi c source-c"><span class="nu16">1.23</span></span></span> 与 <span class="t-c"><span class="mw-geshi c source-c"><span class="nu16">1.230</span></span></span> ，不需要转换到同一内部格式和值。
</p>
 <table class="t-rev-begin">
<tr class="t-rev t-since-c99"><td>
<p>若 <span class="t-lc"><a href="../types/limits/FLT_EVAL_METHOD.html" title="c/types/limits/FLT EVAL METHOD">FLT_EVAL_METHOD</a></span> 指示，可以转换浮点常量为大于其所指示类型的范围和精度。例如，常量 <span class="t-c"><span class="mw-geshi c source-c"><span class="nu17">0.1f</span></span></span> 可能在表达式中表现为 <span class="t-c"><span class="mw-geshi c source-c">0.1L</span></span> 。
</p><p>若 <span class="t-lc"><a href="../types/limits.html" title="c/types/limits">FLT_RADIX</a></span> 为 2，则十六进制浮点常量的求值结果，是浮点常量所表示的正确舍入到目标类型的准确值。
</p>
</td>
<td><span class="t-mark-rev t-since-c99">(C99 起)</span></td></tr>
</table>
 <table class="t-rev-begin">
<tr class="t-rev t-since-c23"><td>
<p>拥有相同数值 <span class="mjax" style="display:none">\(\small x\)</span><span class="mjax-fallback texhtml" style="white-space: nowrap;">x</span> ，但有不同量指数的十进制浮点类型的浮点常量，例如 <span class="t-c"><span class="mw-geshi c source-c"><span class="nu0">1230</span>.<span class="me1">dd</span></span></span>、 <span class="t-c"><span class="mw-geshi c source-c">1230.0dd</span></span> 及 <span class="t-c"><span class="mw-geshi c source-c">1.23e3dd</span></span> ，拥有可区别的内部表示。
</p><p>十进制浮点类型的浮点常量的量指数 <span class="mjax" style="display:none">\(\small q\)</span><span class="mjax-fallback texhtml" style="white-space: nowrap;">q</span> 在可能时，以 <span class="mjax" style="display:none">\(\small 10^q\)</span><span class="mjax-fallback texhtml" style="white-space: nowrap;">10<span class="t-su">q<br></span></span> 表示位于 <span class="t-spar">有效数字</span> 最低位的位置的 1 的方式确定。若按以上方式确定的量指数 <span class="mjax" style="display:none">\(\small q\)</span><span class="mjax-fallback texhtml" style="white-space: nowrap;">q</span> 与系数 <span class="mjax" style="display:none">\(\small c = x\cdot 10^{-q}\)</span><span class="mjax-fallback texhtml" style="white-space: nowrap;">c=x·10<span class="t-su">-q<br></span></span> 不能以浮点常量的类型准确表示，则在类型的界限内按需增加 <span class="mjax" style="display:none">\(\small q\)</span><span class="mjax-fallback texhtml" style="white-space: nowrap;">q</span> ，并对应地减少 <span class="mjax" style="display:none">\(\small c\)</span><span class="mjax-fallback texhtml" style="white-space: nowrap;">c</span> ，进行需要的舍入。舍入可能导致零或无穷大。若在 <span class="mjax" style="display:none">\(\small q\)</span><span class="mjax-fallback texhtml" style="white-space: nowrap;">q</span> 抵达最大值后（可能为舍入后的） <span class="mjax" style="display:none">\(\small c\)</span><span class="mjax-fallback texhtml" style="white-space: nowrap;">c</span> 仍在容许范围外，则产生的浮点常量拥有正无穷大值。
</p>
</td>
<td><span class="t-mark-rev t-since-c23">(C23 起)</span></td></tr>
</table>
<h3><span class="mw-headline" id=".E6.B3.A8.E8.A7.A3">注解</span></h3>
<p>默认<a href="../numeric/fenv/FE_round.html" title="c/numeric/fenv/FE round">舍入方向</a>和<a href="../types/limits/FLT_EVAL_METHOD.html" title="c/types/limits/FLT EVAL METHOD">精度</a>在浮点常量转换成内部表示时有效，而且不会引发<a href="../numeric/fenv/FE_exceptions.html" title="c/numeric/fenv/FE exceptions">浮点异常</a>，即使 <a href="../preprocessor/impl.html" title="c/preprocessor/impl"><tt>
#pragma STDC FENV_ACCESS</tt></a> 生效（对于字符串的执行时转换，可使用 <span class="t-lc"><a href="../string/byte/strtof.html" title="c/string/byte/strtof">strtod</a></span> ）。注意它和浮点类型的<a href="constant_expression.html" title="c/language/constant expression">算术常量表达式</a>有别。
</p><p>浮点常量中的字母是无关大小写的<span class="t-rev-inl t-since-c23"><span>，除了在十进制浮点类型的后缀中不能一同使用大写和小写</span> <span><span class="t-mark-rev t-since-c23">(C23 起)</span></span></span>： <span class="t-c"><span class="mw-geshi c source-c"><span class="nu12">0x1</span>.<span class="me1">ep</span><span class="sy2">+</span><span class="nu0">3</span></span></span> 与 <span class="t-c"><span class="mw-geshi c source-c"><span class="nu12">0X1</span>.<span class="me1">EP</span><span class="sy2">+</span><span class="nu0">3</span></span></span> 表示同一浮点值 15.0 。
</p><p><span class="t-lc"><a href="../locale/setlocale.html" title="c/locale/setlocale">setlocale</a></span> 中指定的小数点对浮点常量语法无效：小数点始终是点。
</p><p>不同于整数，不是每个浮点值都能以十进制<span class="t-rev-inl t-since-c99"><span>或十六进制</span> <span><span class="t-mark-rev t-since-c99">(C99 起)</span></span></span>常量语法表示<span class="t-rev-inl t-since-c99"><span>：宏 <a href="../numeric/math/NAN.html" title="c/numeric/math/NAN"><tt>NAN</tt></a> 和 <a href="../numeric/math/INFINITY.html" title="c/numeric/math/INFINITY"><tt>INFINITY</tt></a> 以及如 <span class="t-lc"><a href="../numeric/math/nan.html" title="c/numeric/math/nan">nan</a></span> 的函数提供生成这些特殊值的方式</span> <span><span class="t-mark-rev t-since-c99">(C99 起)</span></span></span>。注意 <span class="t-c"><span class="mw-geshi c source-c"><span class="nu12">0x1</span>.<span class="me1">FFFFFEp128f</span></span></span> ，可能作为 IEEE float NaN 出现，实际上它在该格式中溢出到无穷大。
</p><p>没有负浮点常量；如 <span class="t-c"><span class="mw-geshi c source-c"><span class="sy2">-</span><span class="nu16">1.2</span></span></span> 的表达式被视为<a href="operator_arithmetic.html" title="c/language/operator arithmetic">算术运算符</a>一元负作用于浮点常量 <span class="t-c"><span class="mw-geshi c source-c"><span class="nu16">1.2</span></span></span> 。注意可通过 <span class="t-lc">-0.0</span> 构造特殊值负零。
</p>
<h3><span class="mw-headline" id=".E7.A4.BA.E4.BE.8B">示例</span></h3>
<div class="t-example"><div class="t-example-live-link"><div class="coliru-btn coliru-btn-run-init">运行此代码</div></div>
<div dir="ltr" class="mw-geshi" style="text-align: left;"><div class="c source-c"><pre class="de1"><span class="co2">#include &lt;stdio.h&gt;</span>
 
<span class="kw4">int</span> main<span class="br0">(</span><span class="kw4">void</span><span class="br0">)</span>
<span class="br0">{</span>
    <a href="../io/fprintf.html"><span class="kw851">printf</span></a><span class="br0">(</span><span class="st0">"15.0     = %a<span class="es1">\n</span>"</span>, <span class="nu16">15.0</span><span class="br0">)</span><span class="sy4">;</span>
    <a href="../io/fprintf.html"><span class="kw851">printf</span></a><span class="br0">(</span><span class="st0">"0x1.ep+3 = %f<span class="es1">\n</span>"</span>, <span class="nu12">0x1</span>.<span class="me1">ep</span><span class="sy2">+</span><span class="nu0">3</span><span class="br0">)</span><span class="sy4">;</span>
 
    <span class="co1">// 超出 double 范围的常量。</span>
    <a href="../io/fprintf.html"><span class="kw851">printf</span></a><span class="br0">(</span><span class="st0">"+2.0e+308 --&gt; %g<span class="es1">\n</span>"</span>,  <span class="nu19">2.0e+308</span><span class="br0">)</span><span class="sy4">;</span>
    <a href="../io/fprintf.html"><span class="kw851">printf</span></a><span class="br0">(</span><span class="st0">"+1.0e-324 --&gt; %g<span class="es1">\n</span>"</span>,  <span class="nu19">1.0e-324</span><span class="br0">)</span><span class="sy4">;</span>
    <a href="../io/fprintf.html"><span class="kw851">printf</span></a><span class="br0">(</span><span class="st0">"-1.0e-324 --&gt; %g<span class="es1">\n</span>"</span>, <span class="sy2">-</span><span class="nu19">1.0e-324</span><span class="br0">)</span><span class="sy4">;</span>
    <a href="../io/fprintf.html"><span class="kw851">printf</span></a><span class="br0">(</span><span class="st0">"-2.0e+308 --&gt; %g<span class="es1">\n</span>"</span>, <span class="sy2">-</span><span class="nu19">2.0e+308</span><span class="br0">)</span><span class="sy4">;</span>
<span class="br0">}</span></pre></div></div>
<p>输出：
</p>
<div dir="ltr" class="mw-geshi" style="text-align: left;"><div class="text source-text"><pre class="de1">15.0     = 0x1.ep+3
0x1.ep+3 = 15.000000
+2.0e+308 --&gt; inf
+1.0e-324 --&gt; 0
-1.0e-324 --&gt; -0
-2.0e+308 --&gt; -inf</pre></div></div> 
</div>
<h3><span class="mw-headline" id=".E5.BC.95.E7.94.A8">引用</span></h3>
<div class="t-ref-std-17">
<ul><li> C17 标准（ISO/IEC 9899:2018）：
</li></ul>
<dl><dd><ul><li> 6.4.4.2 Floating constants (p: 47-48)
</li></ul>
</dd></dl>
</div>
<div class="t-ref-std-11">
<ul><li> C11 标准（ISO/IEC 9899:2011）：
</li></ul>
<dl><dd><ul><li> 6.4.4.2 Floating constants (p: 65-66)
</li></ul>
</dd></dl>
</div>
<div class="t-ref-std-c99">
<ul><li> C99 标准（ISO/IEC 9899:1999）：
</li></ul>
<dl><dd><ul><li> 6.4.4.2 Floating constants (p: 57-58)
</li></ul>
</dd></dl>
</div>
<div class="t-ref-std-c89">
<ul><li> C89/C90 标准（ISO/IEC 9899:1990）： 
</li></ul>
<dl><dd><ul><li> 3.1.3.1 Floating constants 
</li></ul>
</dd></dl>
</div>
<h3><span class="mw-headline" id=".E5.8F.82.E9.98.85">参阅</span></h3>
<table class="t-dsc-begin">

</table>

<!-- 
NewPP limit report
Preprocessor visited node count: 2762/1000000
Preprocessor generated node count: 7701/1000000
Post‐expand include size: 62329/2097152 bytes
Template argument size: 17231/2097152 bytes
Highest expansion depth: 15/40
Expensive parser function count: 0/100
-->

<!-- Saved in parser cache with key mwiki1-mwiki_zh_:pcache:idhash:7925-0!*!0!!zh!*!zh!* and timestamp 20211207194738 -->
</div>                    <!-- /bodycontent -->
                                        <!-- printfooter -->
                    <div class="printfooter">
                    来自“<a href="https://zh.cppreference.com/mwiki/index.php?title=c/language/floating_constant&amp;oldid=72851">https://zh.cppreference.com/mwiki/index.php?title=c/language/floating_constant&amp;oldid=72851</a>”                    </div>
                    <!-- /printfooter -->
                                                            <!-- catlinks -->
                    <!-- /catlinks -->
                                                            <div class="visualClear"></div>
                    <!-- debughtml -->
                                        <!-- /debughtml -->
                </div>
                <!-- /bodyContent -->
            </div>
        </div>
        <!-- /content -->
        <!-- footer -->
        <div id="cpp-footer-base" class="noprint">
            <div id="footer">
                        <div id="cpp-navigation">
            <h5>导航</h5>
            <ul><li><a href="https://zh.cppreference.com/w/c/language/floating_constant">Online version</a></li><li>Offline version retrieved 2022-01-01 00:37.</li></ul></div>
                        <ul id="footer-info">
                                    <li id="footer-info-lastmod"> 本页面最后修改于2021年10月19日 (星期二) 21:54。</li>
                                    <li id="footer-info-viewcount">此页面已被浏览过5,045次。</li>
                            </ul>
                    </div>
        </div>
        <!-- /footer -->
        <script>if(window.mw){
mw.loader.state({"site":"loading","user":"missing","user.groups":"ready"});
}</script>
<script src="../../../common/skin_scripts.js"></script>
<script>if(window.mw){
mw.loader.load(["mediawiki.action.view.postEdit","mediawiki.user","mediawiki.page.ready","mediawiki.searchSuggest","mediawiki.hidpi","ext.gadget.MathJax","ext.gadget.ColiruCompiler"], null, true);
}</script>
<script src="../../../common/site_scripts.js"></script>
<script type="text/javascript">
var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-2828341-1']);
_gaq.push(['_setDomainName', 'cppreference.com']);
_gaq.push(['_trackPageview']);
</script><!-- Served in 0.744 secs. -->
	</body>
<!-- Cached 20211207194738 -->
</html>